# Training In Register & Micro Operation

Register Transfer And Micro Operation •

The Multiplexers And Three State Buffer •

Memory Transfer •

Arithmetic Micro Operation •

Design Logic Operation •

Hard Ware Implementation •

Selective – Operations •

Shift Micro Operation •

#### Introduction

# ان اى جهاز حاسب ألى هو عبارة عن تصميم معقد من مجموعة اجزاء اليكترونية تعمل مع بعضها بشكل منظم وتلقائى ولكل منها وظيفته الخاصة التى يقوم بها من خلال وضعه فى مكانه الصحيح.

# ولكن كيف تعمل هذه الاجزاء مع بعضها البعض بشكل تلقائى؟

ولمعرفة هذا يجب ان نتعرف على ادق تفاصيل الهاردوير. ونجد ان كثير من الناس يعتقدون ان مفهوم الهاردوير قاصر فقط على الاجزاء المادية وان ليس له علاقة بحسابات او اى اجرائات برمجية وهذا فهم خاطىء وذلك لان صناعة الهاردوير اساسا تعتمد على البرمجيات المنطقية وتطوير اساليبها لكى تصبح اكثر تقدما وفاعلية مع احدث البرامج العالمية.

وفى هذا القرص التعليمى سنقوم بشرح مبسط للعمليات التى يقوم بها اى حاسب ألى وكذلك البنية الاساسية له وطريقة الذكاء الاصطناعي التى يفكر بها.

#### **CHAPTER 1**

## //Register And Transfer//

#### # سنتطرق الان الى مفهوم Digital System

اذا اعتبرنا ان اى جهاز Digital عبارة عن مجموعة من Models مرتبطة مع بعضها بواسطة كابلات تسمى pass ونعتبر ان هناك عمليات تنفذ على هذه Models وبعد تنفيذها يمكن ان تظل المعلومات التى تحتويها هذه Models ان تبقى كما هى او ان تتغير حسب العملية التى اجريت عليها او ان تنتقل عبر passes الى مكان اخر مثل Data Cable فى الكمبيوتر والذى يحتوى بدوره على ثلاثة انواع من الكابلات :

**Data Cable = Data Pass + Address Pass + Control Pass** 



**Digital System** 

# وفيما يلى تعريف لمعنى العمليات:

Operation : هي عملية تنفذ بخطوات محسوبة

Micro Operation : هي جزء من العملية الرئيسية

## //Transfer Micro Operation//

# هي عملية نقل البيانات من Register الى Register اخر .

: Example : Statement  $R2 \leftarrow R1$ 

Transfer Data In Register R1 To Register R1

ومعانها انتقال البيانات من R1 الى R2.

# كيفية رسم هذه العملية بواسطة دائرة منطقية .

وتعرف هذه العملية بعملية Timing Diagram

# نجد ان Clocking Pulse تلتقى مع Failing Leakage ويحدث Load للعملية اى تحميل لها لكى تنفذ

اذا عندما يكون Load = 1 يحدث



**Timing Diagram** 

#### **CHAPTER 2**

## //Multiplexers & Three State Buffer//

Multiplexed بأختصار هو عبارة عن Device يستقبل عدد من الدخول ويعطى خرج واحد

كيفية استعمال Multiplexer مع Register معينة

يحتاج الامر الى بعض الحسابات الرياضية البسيطة لمعرفة عدد Multiplexers التى ستسخدم وعدد الدخول وكيفية اختيار الخرج.

// وسنقوم الان بشرح مثال على ذلك : // لدينا الان عدد Registers ونريد ان نظهر محتويات اى من هما على الشاشة عن طريق وضع الاحتمالات.

Registers are: Register A - Register B - Register C - Register D

: so we can put our calculation

**Number Of Registers = 4** 

Number Of Inputs =  $2 ^ R = 2 ^ 4 = 16INPUT$ 

Number Of Multiplexer = Number Of Bits In Register = 4

Capacity Of Multiplexer = Number Of Register \* 1 = 4 \* 1 = 4Inputs x 1Output

# كيفية رأينا هذه الحسابات لمعرفة عدد ال Multiplexers المستخدمة وكذلك عدد الدخول وسعة

. Multiplexer

# والان نرى تمثيل عملى لهذه الدائرة وكيفية اختيار Register واحد ليظهر على الخرج.



**Bus And Memory Transfer For Four Register** 

# من الرسم نجد لكل نوع من المداخل يتم تخصيص Multiplexer بمعنى:

(A0 - B0 - C0 - D0): ان M0 يأخذ الدخول الاتية

و M1 يأخذ الدخول الاتية: (A1 – B1 – C1 – D1)

( A2 - B2 - C2 - D2) : و M2 يأخذ الدخول الاتية

( A3 - B3 - C3 - D3) : و M3 يأخذ الدخول الاتية

A0-A1-A2-A3 فمثلا يتم اختيار دخل واحد من كل Multiplexer لنفس Register فمثلا يتم اختيار Register وبذلك يكون Register رقم A هو الذي يظهر على الخرج وهكذا .

# والتمثيل الصحيح لهذه الاختيارات في علوم الحاسبات يتم عن طريق جداول تسمى Truth Table والتمثيل الصحيح لهذه الاختيارات في علوم اللذان يقومان باختيار الخرج معا اذا الافتراضات ستكون كالتالى .

| <b>S1</b> | S0 | Register Selected |
|-----------|----|-------------------|
| 0         | 0  | A                 |
| 0         | 1  | В                 |
| 1         | 0  | C                 |
| 1         | 1  | D                 |

## //Three - State Bus Buffer//

# يعتمد في هذا الجزء بشكل اساسى على حماية المعلومات وتمريرها كما هي .

# واليك تركيب هذا ال Device



# هذا الجزء بأختصار هو عملية حماية للبيانات التي تمر من خلاله ومعنى ذلك ان البيانات التي تمر من خلاله تمر كما هي دون اي تغيير . ويتضح من الرسم ان له ثلاثة اذرع . A ويمثل الدخل . Y وتمثل الخرج

# والان سنرى كيف يمكن اختيار Register الذى سيظهر على الخرج بواسطة



# فى هذا الشكل نرى كيف تم عمل دائرة بواسطة Decoder & 3State Buffer وذلك لعمل اختيار لاحد Register A لكى يظهر على الخرج هو Register A الذى ظهر على الخرج هو Register كى يظهر على الخرج هو Decoder الذى ظهر على الخرج هو Decoder وعن طريق رسم نفس الدائرة بواسطة Decoder اخر وتوصيل الكابلات بخط ارضى رئيسى نجد انه يمكن اختيار Register اخر وهكذا .

#### **CHAPTER 3**

## **Memory Transfer**

# يوجد عمليتين من عمليات انتقال Data من الذاكرة .

\* عملية تخزين في الذاكرة ( Writing )

.عملية قراءة من الذاكرة ( Reading

# عملية القراءة ( Reading )

**Read : Reading operation**  $DR \leftarrow M[AR]$ 

ومعنى هذه الجملة انه يتم قراءة البيانات التي توجد في العنوان المسمى AR في الذاكرة ووضعه في DR

# عملية الكتابة (Writing)

Write: Writing operation M[AR]

ومعنى هذه الجملة ان يتم تخزين البيانات التي توجد في R1 في العنوان المسمى AR الذي يوجد في الذاكرة

#### **CHAPTER 4**

# **//Arithmetic Micro Operations//**

# هذا النوع من العمليات يطبق على المعلومات التي توجد في Register وتنقسم الى اربع اجزاء رئيسية .

**Transfer Micro Operation From Register To Another** 

Arithmetic Micro Operation On Numeric Data Stored In Register

Logic Micro Operation On Non – Numeric Data Stored In Register

Shift Micro Operation On Data Stored In Register

# عملية نقل المعلومات من Register الى اخر

# عمليات حسابية على بيانات زقمية موجودة داخل Register

# عمليات منطقية على البيانات الموجودة داخل Register

# عملية ازاحة للبيانات من اليمين او اليسار داخل Register الواحد

#### **Basic Arithmetic Micro Operation**

Addition - Subtraction - Increment - Decrement - Shift

**Contents Of R1 + R2 Transferred TO R3**  $R3 \leftarrow R1 + R2$ 

Contents Of R1 Minus R2 Transferred To R3  $R3 \leftarrow R1 - R2$ 

**S Complement'1**  $R2 \leftarrow \bar{R2}$ 

S Complement'2

$$R2 \leftarrow R2 + 1$$

S Of R2 Add R1 Transferred To R3'2

$$R3 \leftarrow R1 + R2 + 1$$

**Increment Of R1 By One** 

 $RI \leftarrow RI + 1$ 

**Decrement Of R1 By One** 

 $RI \leftarrow RI - 1$ 

# **Representation Of Different Operations By Gates**

#### //Binary Adder//



# هذه الدائرة بأختصار تمثل Binary Adder وطريقة العمل كالاتى :

// تقوم اول بوابة بجمع اثنين من المدخلات وهما (A0,B0) ثم تضيف على ناتج الجمع ال(CARYY) (CO) اتقوم اول بوابة بجمع اثنين من المدخلات وهما (A0,B0) ثم تضيف على ناتج الجمع التالية وهكذا حتى تنتهى كل فيكون الناتج SO ويتبقى من الناتج CARRY اخر C1 يضاف الى عملية الجمع التالية وهكذا حتى تنتهى كل البيانات ثم نخرج في النهاية بناتج جمع S3, C4 CARRY

#### //Binary Adder - Sub Tractor//



# طريقة عمل هذه الدائرة:

# اذا كانت M = 0

$$A \oplus 0 = B$$
,  $C0 = 0$   
 $A0 + B0$ ,  $C0 = 0$ ,  $S0 = A0 + B0$ 

# اذا كانت M = 1 :

 $B \oplus 1 = \overline{B}$ , C0 = 1

B Is Complemented + 1 2's Complement

A + 2'S Complement B A - B, C0 = 1

# رأينا كيف استطعنا بهذه الدائرة ان نقوم بالعمليتين معا جمع وطرح فعندما تكون الاختيار = 0 نجد ان العملية تكون جمع وذلك لان الصفر يمرر الناتج كما هو خلال بوابة XOR اما عندما يكون الاختيار = 1 فنجد ان العملية تتحول الى طرح وذلك لان الناتج يكون مع الواحد الصحيح خلال هذه البوابة هو بمثابة Complement للرقم

# //Binary Incremented//



# تبداء عملية الجمع بأضافة 1 على A0 ثم ينتج S ويتبقى C1 ويكون دخل جديد لعملية الجمع التالية مع A1 و تبداء عملية الجمع بأضافة 1 على ال Register و هكذا حتى ننتهى فتكون العملية بمثابة اضافة 1 على ال

#### //Arithmetic Circuit//

# ان القاعدة التركيبية لهذه الدائرة هي مجموعة من بوابات الجمع Adder Gates موصلة مع بعضها على التوازي ويوجد تحكم في عدد ونوع Inputs وبذلك نستطيع ان نحصل على عدد مختلف من العمليات الرياضية المختلفة وتعتبر هذه الدائرة الاكثر تعقيدا .



# شرح عمل الدائرة:

يوجد 4 دخول لهذه الدائرة تطبق على عدد 4Bites فقط ويوجد 4 بوابات Full Adder

كل دائرة تحتوى على 4Bites و 4Multiplexer وذلك لاختيار العمليات المختلفة وعدد الدخول 4Inputs

ل A,B و 4Bites خرج وهي D

4 دخول ل A يذهبون مباشرتا ل Input x بالنسبة لدوائر Adder .

كل دخل من B يذهب الى Data Input لل Multiplexer . ودخل B مباشرتا ونفيه الى

الدخلين 3,2 موصلين ببوابة 3,2 الدخلين

logic 0 ثابتة للدائرة كلها .

Logic 0 يولد من عكس Logic 1

التحكم في اختيار Multiplexer عن \$50,51

ال CARRY يضاف الى بعضه على التوالي

فرج كل Binary Adder يحسب كالتالي Binary Adder

# بواسطة التحكم في CIN1,0, S0,S1 يتولد 8 عمليات رياضية .

#### //Eight Arithmetic Micro Operations//

| S1 | S0 | CIN | INPUT Y   | $ \begin{array}{c} OUTPUT\\ D = A + Y + CIN \end{array} $ | MICRO<br>OPERATION      |
|----|----|-----|-----------|-----------------------------------------------------------|-------------------------|
| 0  | 0  | 0   | В         | D=A+B                                                     | ADD                     |
| 0  | 0  | 1   | В         | D = A + B + 1                                             | ADD WITH CARRY          |
| 0  | 0  | 0   | B         | $D = A + \bar{B}$                                         | SUBTRACT WITH<br>BORROW |
| 0  | 1  | 1   | $\bar{B}$ | $D = A + \bar{B} + 1$                                     | SUBTRACTION             |
| 1  | 0  | 0   | 0         | D=A                                                       | TRANSFER A              |
| 1  | 0  | 1   | 0         | D=A+1                                                     | INCREMENT A             |
| 1  | 1  | 0   | 1         | D=A-1                                                     | DECREMENT A             |
| 1  | 1  | 1   | 1         | D=A                                                       | TRANSFER A              |
|    |    |     |           |                                                           |                         |

#### # كيفية تكوين العمليات:

عندما تكون الاختيارات S0,S1=00 نجد ان الدخل سيكون B=0 وعندما يكون CIN=0 اذا يكون الخرج عندما تكون الاختيارات S0,S1=0 نجد ان الدخل سيكون B=0 على هذه الصورة .

 $\mathbf{D} = \mathbf{A} + \mathbf{B}$ 

ولكن اذا كان CIN = 1 فاءن الخرج يكون على هذه الصورة.

 $\mathbf{D} = \mathbf{A} + \mathbf{B} + \mathbf{1}$ 

وكلاهما تعتبر عملية جمع ولكن الاولى Without Carry والثانية كالاهما تعتبر

عندما تكون الاختيارات S0,S1=0,1=0 نجد ان S0,S1=0,1=0 هى التى تطبق على الدخل وعندما

. يكون CIN = 1 يكون الخرج على هذه الصورة

 $D=A+\bar{B}+1$ 

وهذا يعنى جمع A مع S'2 لل B وهذا بمثابة طرح فيكون الخرج النهائى =

 $\mathbf{D} = \mathbf{A} - \mathbf{B}$ 

ولكن عندما يكون CIN = 0 فيكون الخرج =

**D** = A Transfer Operation

تعتبر عملية انتقال ال A الى الخرج

اما اذا كان CIN = 1 فاءن الخرج

D = A + 0 + 1 Increment To A By 1

عندما تكون الاختيارات S0,S1 = 1,1 = 1 و S0,S1 = 1,1 سيكون الخرج على هذه الصورة .

 $\mathbf{D} = \mathbf{A} - \mathbf{1}$ 

CIN = 1 عندما تكون

D = A - 1 + 1 = A Direct Transfer

عملية انتقال مباشرتا للخرج.

# لاحظ ان عملية الانتقال المباشر قد تمت مرتين و لهذا فاءن Arithmetic Circuit ينتج عنها 7 عمليات مختلفة وعمليتين متشابهتين .

#### **CHAPTER 5**

#### **Logic Micro Operations**

# العمليات المنطقية نجد انه في سياق تلك العمليات تعتمد بشكل اساسى على التفكير المنطقى وليس الرياضي .

R1 = 1010 , R2 = 1100 נينا الان

وسنرى المثال التالي:

والمراد اجراء عملية XOR وارسال الناتج الى Register R1

 $P: R1 \leftarrow R1 \oplus R2$ 

1010 1100

0110

ولاحظ ان  $A\oplus 0=A$  وال  $A\oplus 0=A$  وال  $A\oplus 0=A$  وال وال  $A\oplus 0=A$  وال الشارة التي تعطى امر تنفيذ العملية اذا كانت

= 1 العملية تنفذ واذا كانت = 0 لا تنفذ.

# والان لدينا بعض اشكال العمليات المنطقية:

 $P+Q:R1 \leftarrow R2+R3$ 

P+Q تسمى OR Operation ، و R2 + R3 تسمى OR Operation ،

 $R4 \leftarrow R5 \lor R6$ 

OR Micro Operation تسمى  $R5 \lor R6$ 

والان سنقوم بسرد جدول العمليات المنطقية الشائعة وكذلك جدول الاحتمالات لها:

## // List Of Logic Micro Operations//

| X | Y | F0 | F1 | F2 | F3 | F4 | F5 | F6 | <b>F7</b> | F8 | F9 | F10 | F11 | F12 | F13 | F14 | F15 |
|---|---|----|----|----|----|----|----|----|-----------|----|----|-----|-----|-----|-----|-----|-----|
| 0 | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 1  | 1  | 1   | 1   | 1   | 1   | 1   | 1   |
| 0 | 1 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0   | 0   | 1   | 1   | 1   | 1   |
| 1 | 0 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 1   | 1   | 0   | 0   | 1   | 1   |
| 1 | 1 | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 1  | 0   | 1   | 0   | 1   | 0   | 1   |

| BOOLEAN FUNCTION    | MICRO OPERATION                           | NAME         |
|---------------------|-------------------------------------------|--------------|
| F0=0                | $F \leftarrow 0$                          | CLEAR        |
| FI = XY             | $F \leftarrow A \wedge B$                 | AND          |
| $F2 = X * \bar{Y}$  | $F \leftarrow A \wedge \bar{B}$           |              |
| F3=X                | $F \leftarrow A$                          | TRANSFER     |
| $F4 = \bar{X} * Y$  | $F \leftarrow \bar{A} \wedge B$           |              |
| F5 = Y              | $F \leftarrow B$                          | TRANSFER B   |
| $F6 = X \oplus Y$   | $F \leftarrow A \oplus B$                 | EX - OR      |
| F7 = X + Y          | $F \leftarrow A \wedge B$                 | OR           |
| F8 = (X + Y)        | $F \leftarrow (\bar{A \wedge B})$         | NOR          |
| $F9 = (X \oplus Y)$ | $F \leftarrow (A \stackrel{-}{\oplus} B)$ | EX - NOR     |
| $F10 = \bar{Y}$     | $F \leftarrow \bar{B}$                    | COMPLEMENT B |
| $F11 = X + \bar{Y}$ | $F \leftarrow A \wedge \bar{B}$           |              |
| $F12=\bar{X}$       | $F \leftarrow \bar{A}$                    | COMPLEMNT A  |
| $F13 = \bar{X} + Y$ | $F \leftarrow \overline{A} \wedge B$      |              |
| $F14 = (\bar{XY})$  | $F \leftarrow (A \wedge B)$               | NAND         |
| F15=1               | F ← 1 'S                                  | SET ALL 1'S  |

# //Hard Ware Implementation //



| S1 | S0 | OUTPUT             | OPERATION  |
|----|----|--------------------|------------|
| 0  | 0  | $E = A \wedge B$   | AND        |
| 0  | 1  | $E = A \vee B$     | OR         |
| 1  | 0  | $E = A \oplus B$   | XOR        |
| 1  | 1  | $E = \overline{A}$ | COMPLEMENT |

#### //Selective – Set Operations Sets//

1010 1100

1110

A Before . وهذا يمثل الرقم قبل العملية A = 1010

Logic Operand . وهذا يمثل المعامل B = 1100

لاحظ ان الرقمين على اليسار من B=1 للرقمين على يمين ولذلك يتم تغيير هذه الارقام التى توجد على يسار ال A الى A فيصبح الناتج = A ونجد ان الرقمين على يمين A اذا الرقمين على يمين A يضلوا كما هم .

#### //Selective - Complement Operation//

1010

1100

0110

# نفس العلامة السابقة مع اختلاف هو ان نحضر 1's للرقمين على اليسار من B .

//Selective - Clear Operation//

1010

1100

0010

# اذا كان الرقمين على اليسار من B=1's للرقمين على اليمين اذا الرقمين على لايسار من B يتم وضعهم

= 0 وتسمى العملية Clear

#### //Mask Operation//

1010

1100

1000

# الرقمين على يمين A يتم وضعهم = 0 وذلك لان الرقمين التابعين لهم في B=0 لهم

وسمى هذه العملية بعملية القناع Masking

اما الرقمين على يسار A لم يتم تغيرهم وذلك لان الارقام التابعة لهم في B=1 لهم .

#### //Insertion Operation//

# وتعتبر من اهم العمليات المنطقية اذ تكمل على مرحلتين .

المرحلة الاولى .

01101010 00001111

00001010

# لاحظ ان ال A هو الرقم و B هو Mask اذا المراد اولا عملية Masking لل A

نريد حذف الاربع ارقام على يسار A وتستبدلهم بأرقام جديدة ولذلك تم عمل Mask لهم وذلك بوضع اربع ارقام اصفار 0000

اما الارقام على يمين A تم وضع تحتهم s' حتى يظلوا كما هم .

**Insert The New Value** 

بعد ذلك يتم عمل Insertion للقيمة الجديدة

 $\begin{array}{c} 00001010 \\ 10010000 \end{array}$ 

10011010

ولاحظ هنا ان العملية عملية جمع .

# عندما نرید ان نختبر اذا کان القیمیتین متساویتین نعمل لهم EX – OR حیث یکون الناتج الکلی = 0

1010

1010

0000

#### //Shift Micro Operations//

# الانواع:

(Logic Shift Micro Operations)

(Circular Shift Micro Operations)

(Arithmetic Shift Micro Operations)

 $R \leftarrow SHLR$  **Shift** – **Left** 

 $R \leftarrow SHRR$  Shift – Right

 $R \leftarrow Cil\ R$  Circular Shift – Right

 $R \leftarrow Cir R$  Circular Shift – Right

 $R \leftarrow ASHLR$  Arithmetic Shift – Left

 $R \leftarrow ASHRR$  Arithmetic Shift - Right

# Shift معناها الازاحة والعمليات ببساطة هي اما ازاحة الرقم يمينا او يسارا او تدويره ثم ازاحته .

#### **CHAPTER 6**

## //Basic Computer Organization//

| Stored Program Organization                                                                  |
|----------------------------------------------------------------------------------------------|
| Computer Registers                                                                           |
| asic Registers<br>ommon Bus System                                                           |
| Computer Instruction                                                                         |
| nstruction Format<br>nstruction Set                                                          |
|                                                                                              |
| # الان نبداء في شرح البنية الاساسية لاى جهاز كمبيوتر:                                        |
| ونبداء بتعريف عملية Register Transfer : وهي لغة تستخدم في وصف العمليات التي تحدث داخل الحاسب |
| وتتوقف عليها عملية تصميم الهاردوير داخل الحاسب .                                             |
| # كيفية سير المنظومة الداخلية لعمل الحاسب الالى:                                             |
| كيف يتم تنظيم خطوات برنامج داخل الحاسب لتشغيله .                                             |
| الحاسب يتعامل فقط مع لغة Binary اى 0,1 وهذه لغة لايستطيع المستخدم ان يفهمها فما الحل .       |

الصورة العامة \*

اى عملية يتم تنظيمها من خلال برنامج يقوم المستخدم بوصفه

وتسمى اللغة العالية High Level Language

Programmer..... High Level Language

اى اللغة التي يفهمها الحاسب.

اما اللغة التي يفهمها الحاسب.

Low Level Language......Machine

ويتم التحويل بينهما عن طريق Compiler

High Level Language...... Compiler ......Assembly......Low Level Language

مثال توضيحي .

 $HLL \rightarrow LLL$ ,  $5+6 \rightarrow ADD$  5, 6

نرى الان كيف يتم تحويل لغة الامستخدم الى لغة تفهمها الالة . From 5 + 6 to ADD 5.6

الإن نرى كيف التحويل بين اللغة التي يفهمها الحاسب والتي يفهمها المستخدم في الشكل اسفل

نحدد العملية والمعاملات فالعملية هي جمع وكود الجمع الذي يفهمه الحاسب هو 101 والمعاملات او Data

هى 5,6 والكود الذى يفهمه الحاسب هو 101 = 5 و 110 = 6

Assembly ------ Assembler ----- Machine Code

اما اذا كنا سنتعامل مع متغيرات يجب حجز مكان في الذاكرة كالتالي .

 $X + Y \rightarrow ADDX$ , Y

 ${f X}$  هو عنوان مكان في الذاكرة و  ${f Y}$  هو عنوان مكان اخر حيث يتم جمع المحتويات بداخلهما .

اذا اى Instruction يجب تحويلها الى بواسطة Assembly الى Machine Code لكى يفهمها الحاسب

وبعد ذلك يتم تخزينها في الذاكرة Main Memory

وعملية التخزين تتم على مرحلتين:





# الان نرى تركيبة اى عملية داخل Register

Data1,Data2 هى اوامر العمليات و operand هو المعامل و x,y هما Instruction مرحلة التنفيذ تتم على ثلاثة مراحل :.

**Fetch instruction Register -1** 

وهى تقوم بعملية نقل Instruction الى Register داخل المعالج

#### **Decod Instruction – 2**

عملية يقوم بها Control Unit ويتم من خلالها تحديد العملية الموجودة داخل Register وتحدد من خلالها جزء العملية داخل Instruction

Execute -3

تنفيذ العملية بعد تحديدها من خلال Arithmetic Logic او Arithmetic Unit

اذا العمليات تتم على مرحلين اساتين:

1 - نقل البيانات الى مجموعة من Registers

2 - تنفيذ العملية بواسطة Alu ومحتوى Register وبعد ان تتم العملية يتم اعادة تخزينها في Memory ملحظة : - لا يمكن تنفيذ اى عملية داخل Memory ولكن يتم نقلها الى Register وتنفيذها بواسطة Alu واعادتها الى Memory

اذا منظومة الحاسب الالى تعتمد بالاساس على

1 – مجموعة من Register و Control And Timing Unit لتحديد نوع العملية ومتى تنفذ

2 - مجموعة التعليمات التي يعمل عليها الحاسب الالي والتي تسمى Instruction

التعليمات لا تختلف من جهاز الى جهاز بشرط ان تكون من نفس العائلات:

مثلا : -

AppleMachintouse ابل ماكينتوش لها مجموعة اوامر خاصة بها

Motorola موتورلا لها مجموعة اوامر خاصة بها

ولكن من ناحية Software فهو المسئول عن عمل Compile لاى برنامج والذى يختلف هى كيفية تمثيل العملية من جهاز لاخر

مجموعة Register الاساسية التي توجد داخل اي حاسب الي والتي يبني عليها عمل الحاسب: -

فى الحقيقة نجد ان اى حاسب الى بل ابسط حاسب الى يجب ان يحتوى على Registers هذا بالإضافة الى Main Memory واليك التمثيل التالى للبنية الاساسية للكمبيوتر:

**Main Memory Data Register Accumulator Register** DR PC  $\mathsf{AR}$ AC IR TR INP.R OUT.R

# وفيما يلى سنرى فائدة كل Register ودوره في اداء مهمة للكمبيوتر:

Memory او بیانات یتم قرائتها من Memory او بیانات یتم قرائتها من Data Register اذا ای بیانات تقراء او تکتب الی Memory یتم نقلها اولا الی DR

وبناء على ذلك فاءن حجم DR = حجم Word داخل

و memory هي عبارة عن مجموعة من Registers متتالية مع بعضها البعض.

Address Register : يشير الى عنوان مكان في الذاكرة ليتم التعامل مع هذا المكان .

اذا لتعامل مع اى مكان يجب تحميله اولا الى AR وهو يشير الى مكان واحد ويحدد عدده حسب عدد الاماكن الموجودة في الذاكرة .

AR = N اذا کان حجم الذاکرة مثلا ا

AR = 2Bits اذا كان حجم الذاكرة = 4 = 2

AR = 4Bits اذا كان حجم الذاكرة = 16 = 16 اذا عدد

ومن ذلك نستخلص ان هناك نوعين من R يتعاملوا مع Memory وهما AR,DR

Programmer Counter : يحمل عناوين اماكن داخل الذاكرة وهو عنوان المكان التالى لعملية التنفيذ . عند تنفيذ البرنامج لاول مرة سيتم نقل اول عنوان الى PC ثم ينتقل الى AR لينفذ ثم PC يعمل عمل عمل Increment اضافة واحد وهو الخطوة التالية للعملية التى تنفذ حاليا وبالتالى يعمل البرنامج اوتوماتيكيا ونجد ان حجم PC = حجم PC

Instruction Register : يحتوى على Instruction الجارى تنفيذها

IR<-----> يشير الى عنوان مكان فى الذاكرة -----> ينتقل الى-----> يشير الى عنوان مكان فى الذاكرة -----> ينتقل الى Memory حجم IR = حجم

Memory على Data مؤقتة لإجراء بعض العمليات المعينة وحجم TR حجم TR مؤقتة لإجراء بعض

Input Register : يستخدم لتخزين Input Character ممكن ان يكون حرف او رقم

وحجمه كاقصى حد = 8Bites

8Bites = ويحتوى على Output Character وحجمه : Output Register

Processing Register : يحتوى على اول Data تجرى عليها العملية ويسمى : Accumulator Register

: For Example

ADD 5.6 DR = 6 AC = 5

وبعد ذلك تتم عملية الجمع بواسطة ALU

#### //Computer Instruction//

Instruction Types: انواع العمليات

instruction Formate: نمط العملية

Instruction Cycle : دورة العملية

//Instruction Types//

: Register Reference Instruction – 1

: Input / Output Reference Instruction - 2

Instruction هى فى الاساس عبارة عن مجموعة من Binary Bites وتمثل جزئين جزء يمثل نوع العملية واخر يمثل البيانات التى تتم عليها العملية.

وكل عملية محددة بكود يمثلها



Data يمكن ان توجد في الذاكرة او داخل Internal Register او IP/OP Register وكل نوع له تعامل خاص وبناء على مكان Data يتم تصنيف نوع العملية

**Memory Reference – 1** 

Register Reference – 2

IP/OP Reference - 3

## Examples

ولكن كيف يتمكن الحاسب من تحديد نوع Instruction وبالتالى تنفيذها

اى حاسب الى يستطيع من جزء داخل Instruction تحديد نوع الخطوة وبالتالى تحديد مكان Data وهذا الجزء يسمى Operation Code

الشكل العام للعملية يتكون من ثلاثة اجزاء:

#### **Instruction Formate**



Mode Bit

كما نرى الثلاثة اجزاء الرئيسية هما:

Mode Bit - Opcode - Address

ونجد ان محتوى Opcode ينتقل الى Decoder لكى يتم تحديد نوع الخطوة التى ستنفذ ونوع العملية



وظيفة كل جزء من اجزاء العملية:

(Operation Code) : والذي يختصر الي

يقوم بتحديد ما اذا كانت نوع العملية I/P,O/P Reference يقوم بتحديد ما اذا كانت نوع العملية

والذي يحدده I

I/P,O/P Reference واذا کان I=1 تکون Register Reference اذا کان I=0 تکون

ونبداء اولا باختبار D7 والذى يتضح في الرسم التالى:



#### : Direct Operation

فى هذا النوع من العمليات نجد ان Address Filed يشير الى مكان وجود البيانات ولذلك تسمى بالعملية المباشرة .



نجد ان Address Filed اشار مباشرتا الی عنوان Data

#### : Indirect Operation

هنا نجد ان Address Filed يحتوى على عنوان مكان هذا المكان يحتوى على عنوان Address Filed

#### یشیر الی عنوان مکان



نجد هنا ان 456 قد اشار الى عنوان مكان هذا المكان هو 789

هذا المكان اشار الى عنوان البيانات وهي 0009

اذا الاختلاف هو الوصول الى عنوان البيانات بطريقة مباشرة او غير مباشرة ويحدد نوع العملية و Register الذي تجرى عليه العملية على اساس Bites الموجودة في Address .

# كيفية تنفيذ الخطوة داخل البرنامج: Instruction Cycle

مراحل التنفيذ:

: Fetch

في هذه المرحلة يتم انتقال البيانات من الذاكرة الى Instruction Register

: Decode

يتم تحديد نوع العملية - تحديد البيانات

: Execute

يتم تنفيذ العملية على البيانات

# الشيفرات التي تشير الى مراحل التنفيذ:

: Fetch

 $T0: AR \leftarrow PC$ 

 $T1: IR \leftarrow M[AR], PC \leftarrow PC + 1$ 

#### : Decode

تحليل محتوى الخطوة الموجودة في AR

 $T2: Decoder \to IR(12, 13, 14), AR \to IR(0 \to 11), I \to IR(15)$ 

نجد ان 12و 13و 14 يتم عن طريق ال Decoder تحديد نوع العملية

0 الى 11 عن طريق AR يشير الى عنوان Data

Register ا يتحدد نوع ال 15

#### : Execute

مرحلة التنفيذ وتعتمد على نوع العملية:

والذى يحدد العملية Address Field ويوجد فيه Bit ويوجد فيه Address Field واحد فقط يحدد نوع العملية ونوع العملية الذى تجرى عليه العملية

T3 D7 \( \bar{I} : EXecute Register Reference \)

T3 D7 I : Execute IP/OP Register Reference

T3  $\bar{D}$ 7  $\bar{I}$ : Read Data Direct

T3 D7 I: Read Data Indirect

# والان ناتى لكيفية تنفيذ Register – Reference Instruction



# كيفية كتابة كود العملية:

القواعد: اى خطوة يبداء من اليسار ب 7 تكون Register – Reference Instruction ويتبقى الترتيب الكودى

يتم تحديد العملية و Register الذي تجرى عليه العملية عن طريق Bit واحد فقط يكون هو Active والباقة OFF والباقة .

لاحظ ان خط السير يبداء الان من اول Bit على اليسار الى اخر Bit على اليمين يتم تنقيل الواحد الصحيح من اليسار الى اليمين حتى يتولد 12 عملية مختلفة .

1 - عملية Clear وهي تحويل محتوى AC الى 0

ونلاحظ ان T3 D7 BAR I ثابتة لجميع العمليات اى من I وال Opcode الى BIT رقم 12 ثابتين ولذلك سنعوض عنهم في كل العمليات التالية ب R

اذا R = T3 D7 BAR I

 $CLEAR \rightarrow CLA \rightarrow 7800$  $7800 CLA RB11: AC \leftarrow 0$  الشفرة:

Extended Flip Flop = 0 وتسمى CLE عملية – 2 هذا النوع يوضع فيه Carry , Carry out , Over

الشقرة:

EXTENDED FLIP FLOP  $\rightarrow$  CLE  $\rightarrow$  7400

 $7400 CLE RB10 : E \leftarrow 0$ 

3 - عملية CMA تحويل 1'S الى محتوى 3

الشفرة:

 $CMA \rightarrow 7200$ 

 $7200 \, CMA \, RB9 : AC \leftarrow \bar{AC}$ 

Flip Flop الى محتوى S'1 تحويل CME - 4

الشفرة:

 $CME \rightarrow 7100$ 

 $7100 \, CME \, RB8 : E \leftarrow \overline{E}$ 

E الى اليمين من خلال Bit Ac دوران محتوى CIR – 5

والرسم يوضح عملية الدوران عن E

الشيفرة:

 $CIR \rightarrow 7080$ 

7080 CIR RB7:  $AC(15) \leftarrow E$ , SHR(AC),  $E \leftarrow AC(0)$ 







الشفرة:

 $CIL \rightarrow 7040$ 

7040 CIL RB6:  $AC(0) \leftarrow E$ , SHL(AC),  $E \leftarrow AC(15)$ 

AC اضافة واحد على AC وتخزين فى INC – 7

الشفرة:

 $INC \rightarrow 7020$ 

7020 INC RB5:  $AC \leftarrow AC + 1$ 

**SPA: Scab If Positive - 8** 

ومعنى العملية انه لو محتوى AC موجب يتم اهمال الخطوة التالية للتنفيذ اى يتم اضافة 1 على AC اذا ولا يتم اختبار AC في AC اذا كان C ----- + واذا كان C ----- -

الشفرة:

 $SPA \rightarrow 7010$ 

7010 SPA RB4: IF AC(15) = 0,  $PC \leftarrow PC + 1$ 

SNA: Scab If Negative - 9

اى اذا كانت المحتوى = 1 اى القيمة سالبة يترك الخطوة التالية للتنفيذ

الشيفرة:

 $SNA \rightarrow 7008$ 

7008 SNA RB3: IF AC(15)=1,  $PC \leftarrow PC+1$ 

AC = 0 اهمال الخطوة التالية لعملية التنفيذ اذا كان محتوى SZA - 10

الشفرة:

 $SZA \rightarrow 7004$ 

 $7004SZARB2: IFAC=0, PC \leftarrow PC+1$ 

E=0 نفس العملية السابقة لو كان محتوى SZE-11

الشفرة:

 $SZE \rightarrow 7002$ 

 $7002 SZE RB1: IF E=0, PC \leftarrow PC+1$ 

HLT - 12 خطوة توقف البرنامج عن التنفيذ وتستخدم Flip Flop تسمى S لعملية تشغيل البرنامج وايقافه

OFF وعندما تكون S=0 البرنامج ONN وعندما تكون S=1

الشفرة:

 $HLT \rightarrow 7001$ 

 $7001 HLT RB0 : S \leftarrow 0$ 

: Input – Output Instruction #



### 2 فقط وذلك لاهمتهم في الحياة العملية:



# هنا نجد ان timing هو T3 وهو ثابت و ايضا D7 و I ولذلك سنعوض عنهم في الحالتين ب P

INPUT عملية INP - 1

الشفرة:

F800 INP PB11:  $AC 0 \rightarrow 7$  INPUT REGISTER

هذه العملية معنها هو ادخال Bites من 0 الى 7 من AC الى 1 Input Register

OUTPUT عملية OUTP - 2

الشفرة:

 $F400 OUTP PB10 : OUTR \rightarrow AC0 \rightarrow 7$ 

ومعناها من 0 الى 7 داخل AC يذهب الى OUTPUT Register

# نتطرق الان الى بعض العمليات الشهيرة مثل SKI وهي متى يتم تحديد قراءة Data من المفاتيح او خروجها الى الشاشة عن طريق I/P Flag, output Flag

I/P Flag = 1 اهمال خطوة تنفيذ عندما يكون SKI – 1

الشفرة:

 $F200 SKI PB9 : IF (FGI=1) : PC \leftarrow PC+1$ 

O/P Flag = 1 اهمال خطوة لو كان SKO - 2

الشفرة:

 $F100 SKO PB8 : IF (FGO=1), PC \leftarrow PC+1$ 

ملاحظات هامة:

اى برنامج ينفذ بنفس الخطوات المكتوبة ولكن فى بعض اللحظات اثناء التنفيذ توجد عملية اخرى يجب تنفيذها خارج البرنامج اذا كيف يتم ترك البرنامج وتنفيذ العملية والرجوع اليه مرة اخرى

يتم عمل Signal تسمى Incrupt وتوجد عمليتين من هذا النوع:

ION: Incrupt On - 1

ومعناها تنفيذ العملية الخارجية

الشفرة:

F080 ION PB7: IEN ←1

ومعنى IEN اى Flag Enable

**IOF**: Incrupt Off – 2

وعناها انهاء العلمية الخارجية واستكمال البرنامج الاساسى

 $F040 IOF PB6 : IEN \leftarrow 0$ 

ومعنى IEN = 0 اى Flag Disable

#### -: Memory Reference Instruction #





# نجد امه فى العملية الاولى Direct يتم اهمال t3 وتشغيل t4 لقراءة Address و t5 للتنفيذ و t5 و كل التنفيذ و t5 ولكن فى العملية الثانية Indirect نجد ان t3 تشير الى عنوان مكان و t4 تشير الى عنوان البيانات و t5 للتنفيذ

وبالتالى يكون t4 لقراءة البيانات و t5 للتنفيذ في كلا الحالتين

اذا يوجد لدينا 2clocks واحدة للقراءة وواحدة للتنفيذ

الاوامر الهامة في هذه الجزئية:

#### AND TO AC - 1

الشفرة:

 $T4D4:DR \leftarrow M[AR]$ 

 $T5D4:AC \leftarrow AC \land DR,SC \leftarrow 0$ 

ومعناها عند T4 يتم انتقال البيانات من الذاكرة الى DR وعند T5 يتم اضافة البيانات التى فى DR على AC على AC وانتقالها الى AC

ADD TO AC - 2

الشفرة:

 $D4T4:DR \leftarrow M[AR]$ 

 $D4T5:AC \leftarrow AC + DR, E \leftarrow COUT, SC \leftarrow 0$ 

LDA: Load To AC - 3

الشفرة:

 $D4T4:DR \leftarrow M[AR]$ 

 $D4T5:AC \leftarrow DR, SC \leftarrow 0$ 

STA: Store To AC - 4

الشفرة:

 $D3T4:M[AR]\leftarrow AC,SC\leftarrow 0$ 

**BUN: Branch Unconditionally - 5** 

الشفرة:

 $D4T4:PC \leftarrow AR,SC \leftarrow 0$ 

BSA: Branch And Save Return Address - 6

الشفرة:

 $M[AR] \leftarrow PC$ ,  $PC \leftarrow AR + 1$ 

ISZ: Increment And Skip If Zero - 7

الشفرة:

 $D6T4:DR\leftarrow M\left[AR\right]$ 

 $D6T5: DR \leftarrow DR + 1, SC \leftarrow 0$ 

 $D6T6: M[AR] \leftarrow DR$ ,  $IF(DR=0)THEN(PC \leftarrow PC+1, SC \leftarrow 0)$ 

تم بحمد الله وتوفيقه انهاء هذا الكتاب واعتذر عن اى خطىء او عدم وضوح بعض الكلمات وذلك نظرا لضيق الوقت وعلى قارىء الكتاب ارسال اى استفسارات الى صاحب الكتاب هذا الكتاب ضمن سلسة واسعة من كتب مبادىء فى الهاردوير سيتم تن شاء الله تصميمها و ايداع تلك الكتب فى موقع الكتب العربى السلسلة القادمة

(General Register Organization)

(Register Stack)

(Spice Programmer)

(VLSI)

(Control And Simulation)

مؤلف الكتاب لا يسمح بنسخ او محاولة تغيير في المضمون العربية المنسمون على شهادة - الهندسة الاليكترونية - بمنوف - جمهورية مصر العربية

البريد الاليكترونى: memorycode\_84@yahoo.com
يرجى لاى استفسار على محتويات الكاتب ارسال رسالة على هذا البريد او عن طريق المحادثة عن طريق برنامج الياهو